home *** CD-ROM | disk | FTP | other *** search
- ;;; Compiled by f2cl version 2.0 beta 2002-05-06
- ;;;
- ;;; Options: ((:prune-labels nil) (:auto-save t) (:relaxed-array-decls t)
- ;;; (:coerce-assigns :as-needed) (:array-type ':simple-array)
- ;;; (:array-slicing nil) (:declare-common nil)
- ;;; (:float-format double-float))
-
- (in-package "SLATEC")
-
-
- (let ((nterf 0)
- (nterfc 0)
- (nterc2 0)
- (xsml 0.0)
- (xmax 0.0)
- (sqeps 0.0)
- (erfcs (make-array 21 :element-type 'double-float))
- (erc2cs (make-array 49 :element-type 'double-float))
- (erfccs (make-array 59 :element-type 'double-float))
- (sqrtpi 1.772453850905516)
- (first nil))
- (declare (type f2cl-lib:logical first)
- (type (simple-array double-float (59)) erfccs)
- (type (simple-array double-float (49)) erc2cs)
- (type (simple-array double-float (21)) erfcs)
- (type double-float sqrtpi sqeps xmax xsml)
- (type f2cl-lib:integer4 nterc2 nterfc nterf))
- (f2cl-lib:fset (f2cl-lib:fref erfcs (1) ((1 21))) -0.04904612123469181)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (2) ((1 21))) -0.14226120510371365)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (3) ((1 21))) 0.010035582187599796)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (4) ((1 21))) -5.768764699767486e-4)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (5) ((1 21))) 2.7419931252196067e-5)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (6) ((1 21))) -1.1043175507344509e-6)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (7) ((1 21))) 3.8488755420345033e-8)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (8) ((1 21))) -1.1808582533875464e-9)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (9) ((1 21))) 3.233421582605091e-11)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (10) ((1 21))) -7.991015947004547e-13)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (11) ((1 21))) 1.7990725113961456e-14)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (12) ((1 21))) -3.7186354878186934e-16)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (13) ((1 21))) 7.103599003714253e-18)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (14) ((1 21))) -1.2612455119155225e-19)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (15) ((1 21))) 2.0916406941769294e-21)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (16) ((1 21))) -3.2539731029314073e-23)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (17) ((1 21))) 4.7668672097976744e-25)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (18) ((1 21))) -6.598012078285136e-27)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (19) ((1 21))) 8.655011469963763e-29)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (20) ((1 21))) -1.0788925177498063e-30)
- (f2cl-lib:fset (f2cl-lib:fref erfcs (21) ((1 21))) 1.2811883993017004e-32)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (1) ((1 49))) -0.0696013466023095)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (2) ((1 49))) -0.04110133936262089)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (3) ((1 49))) 0.003914495866689627)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (4) ((1 49))) -4.906395650548979e-4)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (5) ((1 49))) 7.157479001377036e-5)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (6) ((1 49))) -1.153071634131233e-5)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (7) ((1 49))) 1.994670590201998e-6)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (8) ((1 49))) -3.642666471599223e-7)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (9) ((1 49))) 6.944372610005013e-8)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (10) ((1 49))) -1.3712209021043661e-8)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (11) ((1 49))) 2.7883896610071374e-9)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (12) ((1 49))) -5.814164724331161e-10)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (13) ((1 49))) 1.2389204917527533e-10)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (14) ((1 49))) -2.690639145306744e-11)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (15) ((1 49))) 5.94261435084791e-12)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (16) ((1 49))) -1.3323867357581193e-12)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (17) ((1 49))) 3.0280468061771326e-13)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (18) ((1 49))) -6.966648814941033e-14)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (19) ((1 49))) 1.6208545410539232e-14)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (20) ((1 49))) -3.809934465250492e-15)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (21) ((1 49))) 9.040487815978833e-16)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (22) ((1 49))) -2.1640061950896078e-16)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (23) ((1 49))) 5.222102233995854e-17)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (24) ((1 49))) -1.2697296023645555e-17)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (25) ((1 49))) 3.109145504276198e-18)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (26) ((1 49))) -7.663762920320385e-19)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (27) ((1 49))) 1.9008192513627456e-19)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (28) ((1 49))) -4.7422072790690395e-20)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (29) ((1 49))) 1.1896492000765284e-20)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (30) ((1 49))) -3.00003559032578e-21)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (31) ((1 49))) 7.602993453043245e-22)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (32) ((1 49))) -1.9359094476068728e-22)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (33) ((1 49))) 4.9513991247733385e-23)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (34) ((1 49))) -1.271807481336372e-23)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (35) ((1 49))) 3.280049600469513e-24)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (36) ((1 49))) -8.492320176822895e-25)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (37) ((1 49))) 2.20691789280756e-25)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (38) ((1 49))) -5.755617245696529e-26)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (39) ((1 49))) 1.5061915336392342e-26)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (40) ((1 49))) -3.954502959018798e-27)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (41) ((1 49))) 1.0415297041515008e-27)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (42) ((1 49))) -2.751487795278766e-28)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (43) ((1 49))) 7.290058205497557e-29)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (44) ((1 49))) -1.9369396459159477e-29)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (45) ((1 49))) 5.160357112051487e-30)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (46) ((1 49))) -1.3784193221930938e-30)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (47) ((1 49))) 3.691326793107069e-31)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (48) ((1 49))) -9.909389590624368e-32)
- (f2cl-lib:fset (f2cl-lib:fref erc2cs (49) ((1 49))) 2.666491705195389e-32)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (1) ((1 59))) 0.07151793102029248)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (2) ((1 59))) -0.026532434337606714)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (3) ((1 59))) 0.001711153977920856)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (4) ((1 59))) -1.6375166345851788e-4)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (5) ((1 59))) 1.987129350055204e-5)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (6) ((1 59))) -2.843712412766556e-6)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (7) ((1 59))) 4.60616130896313e-7)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (8) ((1 59))) -8.227753025879208e-8)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (9) ((1 59))) 1.5921418727709008e-8)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (10) ((1 59))) -3.295071362252843e-9)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (11) ((1 59))) 7.223439760400555e-10)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (12) ((1 59))) -1.6648558133987296e-10)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (13) ((1 59))) 4.010392588237665e-11)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (14) ((1 59))) -1.0048162144257311e-11)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (15) ((1 59))) 2.6082759133003336e-12)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (16) ((1 59))) -6.991110560404025e-13)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (17) ((1 59))) 1.929492333261707e-13)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (18) ((1 59))) -5.470131188754331e-14)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (19) ((1 59))) 1.5896633097626972e-14)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (20) ((1 59))) -4.726893980197554e-15)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (21) ((1 59))) 1.435873376784985e-15)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (22) ((1 59))) -4.4495105618173586e-16)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (23) ((1 59))) 1.4048108847682333e-16)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (24) ((1 59))) -4.51381838776421e-17)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (25) ((1 59))) 1.4745215410451332e-17)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (26) ((1 59))) -4.8926214069457763e-18)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (27) ((1 59))) 1.647612141410647e-18)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (28) ((1 59))) -5.62681717632941e-19)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (29) ((1 59))) 1.9474433822320786e-19)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (30) ((1 59))) -6.82630564294842e-20)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (31) ((1 59))) 2.4219888872986495e-20)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (32) ((1 59))) -8.693414133503069e-21)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (33) ((1 59))) 3.1551803462280853e-21)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (34) ((1 59))) -1.1573723240496088e-21)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (35) ((1 59))) 4.288947161605653e-22)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (36) ((1 59))) -1.6050307420576168e-22)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (37) ((1 59))) 6.063298757453802e-23)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (38) ((1 59))) -2.3114042516979588e-23)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (39) ((1 59))) 8.888778540661886e-24)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (40) ((1 59))) -3.4472605766513764e-24)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (41) ((1 59))) 1.347865460206965e-24)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (42) ((1 59))) -5.311794071125021e-25)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (43) ((1 59))) 2.1093410586197825e-25)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (44) ((1 59))) -8.43836558792379e-26)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (45) ((1 59))) 3.3999825249452087e-26)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (46) ((1 59))) -1.3794523880732423e-26)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (47) ((1 59))) 5.634490311833252e-27)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (48) ((1 59))) -2.3164904344770657e-27)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (49) ((1 59))) 9.58446284460181e-28)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (50) ((1 59))) -3.9907228803301104e-28)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (51) ((1 59))) 1.6721292259444773e-28)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (52) ((1 59))) -7.045991522766013e-29)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (53) ((1 59))) 2.9797684028642063e-29)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (54) ((1 59))) -1.262522466460619e-29)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (55) ((1 59))) 5.395438704542488e-30)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (56) ((1 59))) -2.380992882531459e-30)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (57) ((1 59))) 1.0990528301027616e-30)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (58) ((1 59))) -4.867713741644965e-31)
- (f2cl-lib:fset (f2cl-lib:fref erfccs (59) ((1 59))) 1.5258772641103577e-31)
- (setq first f2cl-lib:%true%)
- (defun derfc (x)
- (declare (type double-float x))
- (prog ((txmax 0.0) (y 0.0) (derfc 0.0) (eta 0.0f0))
- (declare (type single-float eta) (type double-float derfc y txmax))
- (cond
- (first (setf eta (* 0.1f0 (f2cl-lib:freal (f2cl-lib:d1mach 3))))
- (setf nterf (initds erfcs 21 eta))
- (setf nterfc (initds erfccs 59 eta))
- (setf nterc2 (initds erc2cs 49 eta))
- (setf xsml
- (-
- (f2cl-lib:fsqrt
- (- (f2cl-lib:flog (* sqrtpi (f2cl-lib:d1mach 3)))))))
- (setf txmax
- (f2cl-lib:fsqrt
- (- (f2cl-lib:flog (* sqrtpi (f2cl-lib:d1mach 1))))))
- (setf xmax
- (- (+ txmax (/ (* -0.5 (f2cl-lib:flog txmax)) txmax))
- 0.01))
- (setf sqeps (f2cl-lib:fsqrt (* 2.0 (f2cl-lib:d1mach 3))))))
- (setf first f2cl-lib:%false%)
- (if (> x xsml) (go label20))
- (setf derfc 2.0)
- (go end_label)
- label20
- (if (> x xmax) (go label40))
- (setf y (coerce (abs x) 'double-float))
- (if (> y 1.0) (go label30))
- (if (< y sqeps) (setf derfc (+ 1.0 (/ (* -2.0 x) sqrtpi))))
- (if (>= y sqeps)
- (setf derfc
- (- 1.0
- (* x (+ 1.0 (dcsevl (- (* 2.0 x x) 1.0) erfcs nterf))))))
- (go end_label)
- label30
- (setf y (* y y))
- (if (<= y 4.0)
- (setf derfc
- (* (/ (exp (- y)) (abs x))
- (+ 0.5
- (dcsevl (/ (- (/ 8.0 y) 5.0) 3.0) erc2cs nterc2)))))
- (if (> y 4.0)
- (setf derfc
- (* (/ (exp (- y)) (abs x))
- (+ 0.5 (dcsevl (- (/ 8.0 y) 1.0) erfccs nterfc)))))
- (if (< x 0.0) (setf derfc (- 2.0 derfc)))
- (go end_label)
- label40
- (xermsg "SLATEC" "DERFC" "X SO BIG ERFC UNDERFLOWS" 1 1)
- (setf derfc 0.0)
- (go end_label)
- end_label
- (return (values derfc nil)))))
-
-